



# 32-bit Microcontrollers Embedded F LASH for HC 32 F 460 Series

# **Applicable objects**

| Series   | Product Model |
|----------|---------------|
| HC32F460 | HC32F460JEUA  |
|          | HC32F460JETA  |
|          | HC32F460KEUA  |
|          | HC32F460KETA  |
|          | HC32F460PETB  |



# **Table of Contents** Table of Contents

| 1 | Abstract                               | 3        |
|---|----------------------------------------|----------|
| 2 | FLASH Introduction                     | 3        |
|   | FLASH of HC32F460 Series               |          |
|   | 3.1 Introduction                       | 4        |
|   | 3.2 Description                        | 2        |
|   | 3.2.1 Register Introduction            |          |
|   | 3.2.2 Workflow Introduction            | <u>5</u> |
|   | 3.2.3 One Time Programmable Byte (OTP) | 11       |
|   | 3.2.4 Guided exchange                  | 11       |
| 4 | Sample Code                            | 13       |
|   | 4.1 Code Introduction                  | 13       |
|   | 4.2 Code Run                           | 14       |
| 5 | Version Information & Contact          |          |



## 1 Abstract

This application note introduces how to read and write data using the embedded FLASH of HC32F460 series chip.

## 2 FLASH Introduction

#### What is FLASH?

The FLASH interface provides access to the FLASH through the FLASH ICODE, DCODE, and MCODE buses, which provide access to the

FLASH performs programming, erase and full-erase operations; accelerates code execution through a caching mechanism.

## What are the important features of FLASH?

FLASH read, program, erase and full erase operations, boot swap support, security protection and data encryption.

Applicati Page 3 of 18



## 3 FLASH of HC32F460 Series

## 3.1 Introduction

The FLASH interface provides access to the FLASH through the FLASH ICODE, DCODE, and MCODE buses, which provide access to the

FLASH performs programming, erase and full-erase operations; accelerates code execution through instruction prefetch and cache mechanisms.

## 3.2 Description

FLASH read, program, sector erase and full erase operations.

CODE bus 16Bytes prefetch, 64 caches (128bit wide) shared on I\_CODE and D-CODE

buses. Supports FLASH low power reads.

Support for guided exchange.

Support security protection and data encryption.

The capacity is 512Kbytes (32bytes of which are functionally reserved), divided into 64 sectors of

128bit wide data readout.

The OTP (One Time Program) area consists of 1020 bytes, divided into 960 bytes of data area with 60 bytes of latch area.

## 3.2.1 Register Introduction

1) EFM\_FAPRT: Access the EFM register protection register.

8KBytes each, programmed in 4Bytes and erased in 8KBytes.

- 2) EFM\_FSTP: FLASH stop register.
- 3) EFM\_FRMC: Read mode register. It can be configured to insert wait period, cache function, prefetch finger function, etc.
- 4) EFM\_FWMC: Erase mode register. Configure the programming erase mode.
- 5) EFM\_FSR: Status register. View FLASH status, end flags, error flags, etc.
- 6) EFM FSCLR: Status clear register.
- 7) EFM\_FITE: Interrupt permit register. Configure end-of-operation or error interrupt

Applicati Page 4 of 18



permission.

8) EFM\_FSWP: Boot swap status register. This register is used to determine whether the program is reset from sector 0 or sector 1.
Start.

Applicati Page 5 of 18



- 9) EFM\_FPMTSW: FLASH window protection start address register.
- 10) EFM\_FPMTEW: FLASH window protection end address register.
- 11) EFM\_UQID1~3: Unique ID registers.

## 3.2.2 Workflow Introduction

follows:

#### 3.2.2.1 Register unprotected and write protected

The registers of this module are protected by the EFM\_FAPRT register, which masks the normal write operations when in the protected state. The steps to unprotect are as



In the unprotected state, write any value to the EFM\_FAPRT register, and the EFM register will enter the protected state again. Caution:

 In the actual application, if you find that the register value is not written successfully, you should first check whether the EFM register access protection is valid, when the protection is valid, the EFM\_FAPRT register value is read out as 0x00000000.

Applicati Page 6 of 18



#### 3.2.2.2 Sector Erase

EFM provides two types of erase methods, sector erase and full erase. After a sector erase operation is performed on the FLASH, the address within the sector (8Kbytes of space) Data is flushed

to full 1. The sector erasure is set



#### Caution:

- EFM\_FWMC.PEMODE is a permission for the EFM\_FWMC.PEMOD[2:0] setting;
- PEMOD[2:0] should be set to read-only mode after the erase is completed to prevent misuse of FLASH, which may result in erasing the whole sector.

Applicati Page 7 of 18



#### 3.2.2.3 Full Erase

EFM provides two types of erase methods, sector erase and full erase. After a full erase operation on FLASH, the entire FLASH area is flushed to full 1.

The setting steps for full erase are as follows:



#### Caution:

- PEMOD[2:0] should be set to read-only mode after the erase is completed to prevent misuse of FLASH, which may result in erasing the whole sector.

Applicati Page 8 of 18



#### 3.2.2.4 Single programming without readback

The single programming no readback mode is set as follows:



Applicati Page 9 of 18



#### 3.2.2.5 Single programming readback

Single programmed readback mode means that the programmed address is automatically read and compared with the written data after the programming is finished, and the consistency flag is output.

EFM\_FSR.PGMISMTCH.

The single programming readback mode is set as follows:



#### Caution:

- EFM\_FSR.PGMISMTCH is 0, indicating successful programming, 1 means the FLASH address is corrupted and permanently discarded.

#### 3.2.2.6 Continuous Programming

Continuous programming mode is recommended when programming FLASH addresses continuously. Continuous programming mode can save more than 50% of time compared to single programming mode. The frequency should not be lower than 12MHz for continuous programming mode.

A comparison of continuous programming mode and single programming mode events is shown in the following table:

| Symb | Par  | Con  | Minimum | Typical | Maximum | Unit |
|------|------|------|---------|---------|---------|------|
| ols  | ame  | diti | value   | values  | value   |      |
|      | ters | ons  |         |         |         |      |

Applicati Page 10 of



| Tprog  | Word programming time | Single<br>Programming<br>Mode | 43+2* Thclk | 48+4* Thclk | 53+6* Thclk | μs |
|--------|-----------------------|-------------------------------|-------------|-------------|-------------|----|
|        | Word programming time | Continuous programming mode   | 12+2* Thclk | 14+4* Thclk | 16+6* Thclk | μs |
| Terase | Block Erase<br>Time   | -                             | 16+2* Thclk | 18+4* Thclk | 20+6* Thclk | ms |
| Tmas   | Full Erase<br>Time    | -                             | 16+2* Thclk | 18+4* Thclk | 20+6* Thclk | ms |

Note: Thclk is 1 cycle of the CPU clock

Applicati Page 11 of



The continuous

programming setting

procedure is as follows:

#### Note

- If a read operation is performed on FLASH during continuous FLASH programming, an indefinite value will be read.
- Before initiating a dummy read to any FLASH address in sequential programming mode, the
  cache enable function should be disabled to prevent the erroneous data from entering the
  cache pool; at the same time, this dummy read will generate a read conflict bit (i.e.
  EFM\_FSR.RDCOLERR bit).





#### 3.2.2.7 Bus hold/release function

BUSHLDCTL bit in the EFM\_FWMC.BUSHLDCTL register allows you to set whether the bus will be held or released during FLASH programming and erasing.

This control bit must be set to 0 when the FLASH programming and erase instructions are executed on FLASH, and can be freely set as required when the erase instruction is executed in an unintended FLASH space (e.g. RAM).

BUSHLDCTL is 1 (i.e., bus release state during FLASH programming, erase), when programming (except for continuous programming), read/write access to FLASH will be protected before the end of erase (EFM\_FSR.RDY=1), flag bit EFM\_FSR.BUSCOLERR position bit.

#### 3.2.3 One Time Programmable Byte (OTP)

The OTP (One Time Program) area is divided into 15 64-byte blocks of data, each corresponding to a 4Bytes latch address. See Table 9-3 in the user manual for details.

The latch address is used to latch the corresponding data block. When the latch address data is all 1s, the corresponding OTP area data block is programmable; when the latch address data is all 0s, the corresponding OTP area data is not programmable.

All OTP data blocks and latch addresses are not erasable.

The programming of the OTP area is encapsulated in the flashloader and the user can directly manipulate the otp address. For a sample, please refer to Sample code of efm\_otp under EFM module.

### 3.2.4 Guided exchange

EFM provides the boot-swap function. When users upgrade the boot program, they erase sector 0 (0x00000000~0x00001FFF), and if an unscheduled accident (power down, reset) is encountered during the erase, it may cause the whole chip to fail to boot normally. The boot swap function can avoid this situation.

Before erasing sector 0, write the new boot program to sector 1 (0x00002000~0x00003FFF), then program the data 0xFFFF4321 to EFM address 0x0007FFDC and reset the terminal to enable the CPU to start the new boot program from sector 1, then erase sector 0 and reprogram the user program.

The flow of the bootstrap exchange is as follows:

Applicati Page 13 of





When upgrading the bootloader again, the address 0x0007FFDC, where the boot sector swap information is stored, has already been programmed

(The user can determine if the boot swap function has been used by reading the FLASH address or the EFM\_FSWP register.

EFM\_FSWP.FSWP = 0, indicating that sector 0 and sector 1 have been swapped and will be started from sector 1 after the reset), sector 63 needs to be reset.

(0x0007E000~0x0007FFFF) to perform sector erasure before upgrading the bootloader.

Before erasing sector 0, the new bootloader is pre-written to sector 1, and then sector 63 is erased by end

The CPU starts a new boot program from sector 1, and then erases sector 0 to reprogram a new boot program.

The operation flow is as follows:



A sample bootstrap switch can be found in the efm\_switch sample code under the EFM module.

Applicati Page 14 of



# 4 Sample Code

## 4.1 Code Introduction

Users can write their own code to learn to verify the module according to the above workflow, or download the sample code of Device Driver Library (DDL) directly through the website of UW Semiconductors and use the sample of FLASH in it to verify.

The following section briefly describes the configuration involved in this AN DDL-based FLASH module sample efm\_simple code.

1) To unprotect the FLASH registers:

```
/* Unlock EFM. */
EFM_Unlock().
```

2) Enables FLASH:

```
/* Enable flash. */
EFM_FlashCmd(Enable).
```

3) Waiting for FLASH ready:

```
/* Wait fla sh ready. */
while(Set ! = EFM_GetFlagStatus(E FM_FLAG_RDY)).
```

4) Sector erasure:

```
/* Erase sector 62. */
EFM_SectorErase(FLASH_SECTOR62_ADRR)
```

5) Programming FLASH:

```
u32Addr = FLASH_SECTOR62_ADRR.
for(i = 0; i < 10; i++)
{
    EFM_SingleProgram(u32Addr,u32TestData);
    u32Addr += 4.
}
```

6) Lock FLASH register:

```
/* Lock EFM. */
EFM_Lock().
```

Applicati Page 15 of



## 4.2 Code Run

Users can download the sample code (efm\_simple) of the HC32F460 DDL from the UW Semiconductors website and run the code with the evaluation board (EV-HC32F460-LQFP100-050-V1.1) to learn to use the FLASH module.

The following section describes how to run the FLASH sample code on the evaluation board and observe the results:

- Verify that the correct IAR EWARM v7.7 tool is installed (please download the appropriate installation package from the official IAR website and refer to the user manual for installation).
- Download the HC32F460 DDL code from the UW Semiconductors website.
- Download and run the project file in efm\ efm\_simple\ at
  - 1) Open the efm\_simple \ project and open the 'main.c' view as follows:



- 2) Click to recompile the entire project.
- 3) Click Download the code to the evaluation board, break the point at line 105 and 115 code lines respectively, and run at full speed.

Applicati Page 16 of



4) Run the first breakpoint, single-step, check memory, and observe that sector 62 is all 1s. Continue running at full speed to the next breakpoint, where the address is written to the expected value. The base single step is run and the written value is erased.

Applicati Page 17 of



# 5 Version Information & Contact

| Date      | Versions | Modify records  |
|-----------|----------|-----------------|
| 2019/3/15 | Rev1.0   | Initial Release |
|           |          |                 |
|           |          |                 |



If you have any comments or suggestions in the process of purchase and use, please feel free to contact us.

Email: mcu@hdsc.com.cn

Website: http://www.hdsc.com.cn/mcu.htm

Address: 39, Lane 572, Bibo Road, Zhangjiang Hi-

Tech Park, Shanghai, 201203, P.R. China



Applicati AN0100004C